使用Ruby+正则表达式,给定:starting-middle+31313131313@mysite.com我只想获取:31313131313即starting-middle+和mysite.com之间是什么这是我目前所拥有的:to='starting-middle+31313131313@mysite.com'to.split(/\+/@mysite.com.*/).first.strip 最佳答案 在第一个+和第一个@之间:to[/\+(.*?)@/,1]在第一个+和最后一个@之间:to[/\+(.*)@/,1]在最后一个+和最
我需要在Heroku中将默认的ruby字符串编码更改为UTF-8。由于某种原因,它是US-ASCII。$herokuconsoleRubyconsoleformyapp.heroku.com>>"a".encoding=>#但是,如果我在本地运行irb,我会得到不同的结果:$irbruby-1.9.2-p136:001>"a".encoding=>#两者都在ruby1.9.2上运行。我也试过设置这个,但没用:Encoding.default_internal=Encoding.default_external="UTF-8"想法?谢谢,菲利普 最佳答
我的CSV文件中有一行包含一些转义引号:173,"Yukihiro\"TheRubyGuy\"Matsumoto","Japan"当我尝试使用RubyCSV解析器解析它时:require'csv'CSV.foreach('my.csv',headers:true,header_converters::symbol)do|row|putsrowend我收到这个错误:.../1.9.3-p327/lib/ruby/1.9.1/csv.rb:1914:in`block(2levels)inshift':Missingorstrayquoteinline122(CSV::MalformedCS
如果你想拆分以空格分隔的单词列表,你可以使用defwords(text)returntext.split.map{|word|word.downcase}end类似于Python的列表理解:words("getoutofhere")返回["get","out","of","here"]。如何将block应用于字符串中的每个字符? 最佳答案 使用String#chars:irb>"asdf".chars.map{|ch|ch.upcase}=>["A","S","D","F"] 关于rub
假设我有这样一个字符串:"http://something.example.com/directory/"我想做的是解析这个字符串,并从字符串中提取"something"。第一步,显然要检查以确保字符串包含"http://"-否则,它应该忽略该字符串。但是,我如何才能提取该字符串中的"something"?假设这将要评估的所有字符串都具有相似的结构(即我正在尝试提取URL的子域-如果正在检查的字符串确实是一个有效的URL-其中有效以"http://").谢谢。附言我知道如何检查第一部分,即我可以简单地在"http://"处拆分字符串,但这并不能解决全部问题,因为这会产生"http://
我的解决方案是这样的if(not(defined?(@results).nil?))@results+="run"else@results="run"end但我相信还有更简单的东西...... 最佳答案 我可能会这样做:@results=@results.to_s+"run"这是有效的,因为NilClass定义了一个返回零长度字符串的#to_s方法,并且因为实例变量自动初始化为nil。 关于ruby-如何将字符串附加到存在或不存在的变量?,我们在StackOverflow上找到一个类似的
将字符串数组转换为字符串的最佳惯用(最干净)方法是什么,同时保留每个元素的引号。换句话说,从这个:a=["file1.txt","file2.txt","file3.txt"]我需要得到这个"'file1.txt''file2.txt''file3.txt'"这里单引号和双引号可以互换。我知道的最好方法是使用映射和注入(inject)/减少。例如:a.map{|dir|"'"+dir+"'"}.join('')eg2:a.reduce("'"){|acc,dir|acc+=dir+"'"}可以通过避免创建临时字符串(+运算符)来提高性能。但这不是我的主要问题。有没有更简洁的方法来达到相
我有一个像这样的ruby字符串:str="AABBCCDDEEFFGGHHIIJJ01020304050607080910"#20lettersand20numbersinthiscase我想把它分成两半,我可以这样做:str[0,str.length/2]或str.split(0,str.length/2)之后,我需要用字符创建数组,但每个元素的长度为2,如下所示:["AA","BB","CC","DD","EE","FF","GG","HH","II","JJ"],[01,02,03,04,05,06,07,08,09,10]问题是,我找不到一个简洁的方法来转换这个字符串。我可
新手Ruby问题:我正在写:ifmystring=="valueA"ormystring=="ValueB"ormystring=="ValueC"有没有更简洁的方法? 最佳答案 有两种方式:正则表达式:ifmystring=~/^value(A|B|C)$/#Use/\Avalue(A|B|C)\Z/hereinstead#dosomething#toescapenewlinesend或者,更明确地说,if['valueA','valueB','valueC'].include?(mystring)#dosomethingend希
有没有办法创建一个“之前”过滤器来捕获和预处理Sinatra中的所有POST请求? 最佳答案 执行此操作的一种方法是创建自定义condition在过滤器中使用:set(:method)do|method|method=method.to_s.upcasecondition{request.request_method==method}endbefore:method=>:postdoputs"pre-processPOST"end 关于ruby-Sinatra中所有POST请求的前置过滤